Sources/XCMetricsClient/Mobius/Effect Handlers/CacheLogsEffectHandler.swift (40 lines of code) (raw):

// Copyright (c) 2020 Spotify AB. // // Licensed to the Apache Software Foundation (ASF) under one // or more contributor license agreements. See the NOTICE file // distributed with this work for additional information // regarding copyright ownership. The ASF licenses this file // to you under the Apache License, Version 2.0 (the // "License"); you may not use this file except in compliance // with the License. You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, // software distributed under the License is distributed on an // "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY // KIND, either express or implied. See the License for the // specific language governing permissions and limitations // under the License. import Foundation import MobiusCore import MobiusExtras import XCMetricsUtils struct CacheLogsEffectHandler: EffectHandler { private let logManager: LogManager private let logCopyRetries = 5 init(logManager: LogManager) { self.logManager = logManager } func handle(_ effectParameters: (currentLog: URL?, previousLogs: Set<URL>, cachedLogs: Set<URL>, projectName: String), _ callback: EffectCallback<MetricsUploaderEvent>) -> Disposable { do { // Cache other logs that Xcode produced. var cachedLogsURLs = try logManager.cacheLogs(effectParameters.previousLogs, cachedLogs: effectParameters.cachedLogs, retries: 0) // Cache currentLog separately, to keep track of its cached location. var cachedCurrentLogURLs: Set<URL> = [] if let currentLog = effectParameters.currentLog { cachedCurrentLogURLs = try logManager.cacheLogs(Set([currentLog]), cachedLogs: cachedLogsURLs.union(effectParameters.cachedLogs), retries: logCopyRetries) cachedLogsURLs = cachedLogsURLs.union(cachedCurrentLogURLs) } log("Successfully cached logs: \(cachedLogsURLs)") // Retrieve requests that previously failed to upload. let requestsToRetry = try logManager.retrieveLogRequestsToUpload() // Transforms the contents of the cached logs into an actual MetricsUploadRequest. let cachedUploadRequests: Set<MetricsUploadRequest> = Set(requestsToRetry.map { MetricsUploadRequest(fileURL: $0) }) log("Successfully fetched requests that failed to upload previously: \(requestsToRetry))") callback.end( with: .logsCached( currentLog: cachedCurrentLogURLs.first, previousLogs: cachedLogsURLs.subtracting(cachedCurrentLogURLs), cachedUploadRequests: cachedUploadRequests ) ) } catch { exit(1, error.localizedDescription) } return AnonymousDisposable {} } }